package com.example.project.service;

import com.example.project.dto.SafetyTrainBinDTO;
import com.example.project.dto.SafetyTrainBinPageDTO;
import com.example.project.entity.SafetyTrain;
import com.example.project.entity.SafetyTrainBin;
import org.springframework.data.domain.Page;
import org.springframework.data.domain.PageRequest;

import java.util.Date;

/**
 * (SafetyTrainBin)表服务接口
 *
 * @author makejava
 * @since 2024-02-23 15:18:23
 */
public interface SafetyTrainBinService {

    /**
     * 通过ID查询单条数据
     *
     * @param id 主键
     * @return 实例对象
     */
    SafetyTrainBin queryById(Integer id);

    /**
     * 分页查询
     *
     * @param safetyTrain 筛选条件
     * @param pageRequest 分页对象
     * @param startTime
     * @param endTime
     * @return 查询结果
     */
    Page<SafetyTrainBinPageDTO> queryByPage(SafetyTrain safetyTrain, PageRequest pageRequest, Date startTime, Date endTime);

    /**
     * 新增数据
     *
     * @param safetyTrainBin 实例对象
     * @return 实例对象
     */
    SafetyTrainBin insert(SafetyTrainBin safetyTrainBin);

    /**
     * 修改数据
     *
     * @param safetyTrainBin 实例对象
     * @return 实例对象
     */
    SafetyTrainBin update(SafetyTrainBin safetyTrainBin);

    /**
     * 通过主键删除数据
     *
     * @param id 主键
     * @return 是否成功
     */
    boolean deleteById(Integer id);
    /**
     * 实现彻底删除
     */
    boolean deleteById1(Integer data);
    /**
     * 恢复功能
     */
    boolean update1(SafetyTrainBin safetyTrainBin);

    Boolean deleteById2(SafetyTrainBinDTO data);

    Boolean update2(SafetyTrainBinDTO data);
}
